home *** CD-ROM | disk | FTP | other *** search
/ Cream of the Crop 12 / Cream of the Crop 12 (Part II) / Cream of the Crop 12 (Part II).iso / BBS / ADF_140.ZIP / ADF.TXT < prev    next >
Encoding:
Text File  |  1996-03-23  |  45.3 KB  |  1,188 lines

  1.  
  2.  
  3.  
  4.  
  5.  
  6.  
  7.  
  8.  
  9.  
  10.  
  11.  
  12.  
  13.  
  14.  
  15.  
  16.  
  17.  
  18.  
  19.  
  20.  
  21.  
  22.  
  23.  
  24.                   AnDan Software FOSSIL Version 1.40
  25.  
  26.                   Users Manual
  27.  
  28.                   Scandinavian Digital Systems
  29.           AnDan Software FOSSIL Version 1.40                   Users Manual
  30.           ─────────────────────────────────────────────────────────────────
  31.  
  32.  
  33.           Table of contents
  34.  
  35.            1  Overview ...............................................    3
  36.               1.1  Features of ADF ...................................    3
  37.            2  Shareware ..............................................    3
  38.               2.1  Use as shareware ..................................    3
  39.               2.2  How to register ...................................    4
  40.            3  Support and new versions ...............................    5
  41.               3.1  ADF doesn't work ..................................    5
  42.            4  Included files .........................................    5
  43.            5  Installation ...........................................    6
  44.            6  Command line arguments .................................    6
  45.               6.1  port ..............................................    7
  46.               6.2  addr ..............................................    7
  47.               6.2  irq ...............................................    7
  48.               6.4  baud ..............................................    8
  49.               6.5  recbuf,hold,cont ..................................    8
  50.               6.6  trabuf ............................................    8
  51.               6.7  fifo ..............................................    8
  52.               6.8  line ..............................................    8
  53.               6.9  modem .............................................    9
  54.            7  Execution examples .....................................    9
  55.            8  Baud rate calculation ..................................   10
  56.            9  16550 and 16650 FIFO UARTs .............................   11
  57.               9.1  Receiver 16550-FIFO trigger level .................   11
  58.               9.2  Receiver 16650-FIFO trigger level .................   12
  59.               9.3  Transmitter 16650-FIFO trigger level ..............   12
  60.            10 Error messages .........................................   13
  61.            11 Benchmarks .............................................   14
  62.               11.1 Memory consumption ................................   15
  63.               11.2 Execution speed ...................................   15
  64.            12 The ADFComCh program ...................................   16
  65.            13 The ADFDebug program ...................................   17
  66.               13.1 Using ADFDebug ....................................   17
  67.            14 The ADFTerm program ....................................   18
  68.            15 The ADFTest program ....................................   18
  69.            16 Version history ........................................   19
  70.            17 Future versions ........................................   20
  71.  
  72.  
  73.           Copyright (c) 1994-1996 Scandinavian Digital Systems AB
  74.  
  75.           This product, including the manual and the software, is provided
  76.           as is. Scandinavian Digital Systems AB and Anders Danielsson
  77.           disclaims all warranties of any kind, whether expressed or
  78.           implied, and are not liable to you or anyone else for any damages
  79.           or costs due to the use or inability to use this product.
  80.  
  81.           Acknowledgments:
  82.  
  83.           AnDan Software is a trademark of Scandinavian Digital Systems AB.
  84.           FidoNet is a trademark of Tom Jennings.
  85.           Windows is a trademark of Microsoft Corporation.
  86.           X00 is a program made by Raymond L. Gwinn.
  87.  
  88.  
  89.           ─────────────────────────────────────────────────────────────────
  90.           Scandinavian Digital Systems                               Page 2
  91.           AnDan Software FOSSIL Version 1.40                   Users Manual
  92.           ─────────────────────────────────────────────────────────────────
  93.  
  94.  
  95.           BNU is a program made by David Nugent, Unique Computing Pty
  96.           Limited.
  97.           16550 is a device made by National Semiconductor Corporation.
  98.           16650 is a device made by Startech Semiconductor Incorporated.
  99.  
  100.  
  101.  
  102.  
  103.           1  Overview
  104.  
  105.           ADF is a FOSSIL revision level 5 driver, including the additional
  106.           functions defined by Raymond L. Gwinn in X00 v1.50.
  107.  
  108.           ADF is specially designed for users of high speed modems with or
  109.           without the 16550 or the 16650 UART, using DOS or a multitasking
  110.           environment.
  111.  
  112.           ADF was initially written some years ago because other FOSSIL
  113.           drivers did not always work properly in protected mode
  114.           multitasking environments, where the UART is emulated.
  115.  
  116.           ADF is designed to work well with both emulated UARTs and real
  117.           UARTs, without any drawbacks.
  118.  
  119.  
  120.           1.1  Features of ADF
  121.  
  122.           * Always a locked baud-rate.
  123.           * Locked baud-rate of any speed (2 bps - 115200 bps).
  124.           * Defaults to 8 databits, no parity, and 1 stop bit (8N1).
  125.           * Always CTS/RTS handshake. Never DSR/DTR or XON/XOFF handshake.
  126.           * One port per ADF (load ADF in different tasks for many ports).
  127.           * COM-port address configurable (0H-FFFFH).
  128.           * COM-port IRQ configurable (0-15).
  129.           * Full support of the 16550 UART and the 16650 UART.
  130.           * Fills transmit 16550-FIFO buffer with all 16 bytes.
  131.           * Fills transmit 16650-FIFO buffer with all 32 bytes.
  132.           * Receiver 16550-FIFO configurable (1, 4, 8 or 14 bytes).
  133.           * Receiver and transmitter 16650-FIFO configurable.
  134.           * Only 8088/8086 compatible code used.
  135.  
  136.  
  137.           2  Shareware
  138.  
  139.           The files in this package may be copied and distributed if no fee
  140.           is charged, if no changes are done and as no part of other
  141.           products, in purpose to test and evaluate this product for a
  142.           period of 30 days.
  143.  
  144.  
  145.           2.1  Use as shareware
  146.  
  147.           To use ADF.EXE as shareware, you must first execute the supplied
  148.           REGISTER.EXE and register ADF.EXE as shareware.
  149.  
  150.  
  151.           ─────────────────────────────────────────────────────────────────
  152.           Scandinavian Digital Systems                               Page 3
  153.           AnDan Software FOSSIL Version 1.40                   Users Manual
  154.           ─────────────────────────────────────────────────────────────────
  155.  
  156.  
  157.           Run REGISTER.EXE, specify ADF.EXE as file to register and do not
  158.           enter any user name. ADF.EXE may then be used as shareware.
  159.  
  160.           When ADF.EXE is executed it will display the number of used days
  161.           since it was registered as shareware.
  162.  
  163.  
  164.           2.2  How to register
  165.  
  166.           To register ADF and use it for more than 30 days, you should pay
  167.           an even amount equal to the sum of USD 10 in a currency of your
  168.           own choice. Examples of common currencies:
  169.  
  170.                   American Dollars        USD    10
  171.                   Austrian Schillings     ATS   100
  172.                   Belgian Francs          BEF   300
  173.                   British Pounds          GBP     6
  174.                   Canadian Dollars        CAD    15
  175.                   Dutch Guilders          NLG    15
  176.                   German Marks            DEM    15
  177.                   French Francs           FRF    50
  178.                   Italian Lira            ITL 15000
  179.                   Swedish Krona           SEK    60
  180.  
  181.           Please send cash (bills, paper money) in a letter to:
  182.  
  183.                   Scandinavian Digital Systems AB
  184.                   Billerudsgatan 20
  185.                   S-661 30  Saffle
  186.                   SWEDEN
  187.  
  188.           Please include a note, a postcard or the printed REGISTER.TXT,
  189.           with your FidoNet or Internet e-mail address, and you will
  190.           receive an e-mail receipt of your payment.
  191.  
  192.           No other methods of payments are accepted.
  193.  
  194.           After you have sent the money, send an electronic mail through
  195.           FidoNet to Reg at 2:203/620 or through Internet to
  196.           reg@andan.edv.se. The mail should contain the following lines:
  197.  
  198.                   Prod=ADF
  199.                   User=<Your name and your e-mail address, BBS or location>
  200.  
  201.           You will then receive an automatic reply with your private
  202.           registration code, to the address you mailed your registration.
  203.  
  204.           When you specify your user registration name after the "User=",
  205.           you should use your name together with some kind of address or
  206.           location information. Examples:
  207.  
  208.                   User=Anders Danielsson, AnDan BBS, 2:203/620
  209.                   User=Charles Smith, cs@someplace.com
  210.                   User=Hans Schultz, Dernauer Str., Hamburg, Germany
  211.  
  212.  
  213.           ─────────────────────────────────────────────────────────────────
  214.           Scandinavian Digital Systems                               Page 4
  215.           AnDan Software FOSSIL Version 1.40                   Users Manual
  216.           ─────────────────────────────────────────────────────────────────
  217.  
  218.  
  219.           Use at least 16 characters, but not more than 63 characters.
  220.  
  221.           You may also phone AnDan BBS at +46-533-13700 and register
  222.           on-line. The on-line registration is similar to the mail
  223.           registration.
  224.  
  225.           Note, Reg is a program, and it will reply to your origin (from or
  226.           reply) address. Please make sure that your e-mail has a valid
  227.           origin address.
  228.  
  229.           Please note, routed FidoNet e-mail may not work on long
  230.           distances.
  231.  
  232.           All FidoNet e-mail replies from Reg (and from the support) are
  233.           routed, but a copy of the mail is also put on hold at 2:203/620.
  234.  
  235.           If you suspect that routed mail will not work, use crash mail to
  236.           send to Reg, and some hours later do a poll for any hold replies.
  237.  
  238.  
  239.           3  Support and new versions
  240.  
  241.           If you have questions, comments or find bugs in the program,
  242.           please send electronic mail to the author, Anders Danielsson at
  243.           FidoNet 2:203/620 or ad@andan.edv.se.
  244.  
  245.           Well documented reports of new bugs and suggestions are honored
  246.           with a free registration.
  247.  
  248.           The latest version can be file requested as ADF from FidoNet
  249.           2:203/620.
  250.  
  251.           You may also phone AnDan BBS at +46-533-13700, where the newest
  252.           versions and other shareware programs from AnDan Software always
  253.           are downloadable for all users.
  254.  
  255.  
  256.           3.1  ADF doesn't work
  257.  
  258.           ADF is tested to work with many programs, also in different
  259.           environments, that use FOSSIL drivers.
  260.  
  261.           The author is convinced that ADF will work together with all well
  262.           behaved programs, and if not, it is our intention to make it work
  263.           with those programs as quickly as possible.
  264.  
  265.           However, it is not our policy to make memory or time consuming
  266.           changes in ADF to make it work with badly behaved programs that
  267.           do not use a FOSSIL correctly.
  268.  
  269.  
  270.           4  Included files
  271.  
  272.  
  273.  
  274.  
  275.           ─────────────────────────────────────────────────────────────────
  276.           Scandinavian Digital Systems                               Page 5
  277.           AnDan Software FOSSIL Version 1.40                   Users Manual
  278.           ─────────────────────────────────────────────────────────────────
  279.  
  280.  
  281.           You should have received the following files:
  282.  
  283.           File name:    Description:
  284.  
  285.           ADF.TXT       This file
  286.           ADF.EXE       The FOSSIL driver
  287.           ADFCOMCH.EXE  Checks COM-ports
  288.           ADFDEBUG.EXE  FOSSIL debugger
  289.           ADFTERM.EXE   Very small and simple communication program
  290.           ADFTEST.EXE   FOSSIL tester
  291.           ADFCOM1.BAT   Example of use of ADF with COM1
  292.           ADFCOM2.BAT   Example of use of ADF with COM2
  293.           FILE_ID.DIZ   File description
  294.           REGISTER.TXT  Registration form
  295.           REGISTER.EXE  Registration program
  296.  
  297.  
  298.           5  Installation
  299.  
  300.           Just copy ADF.EXE to a directory included in your PATH.
  301.  
  302.           If you are only running DOS, edit your AUTOEXEC.BAT and insert a
  303.           line that loads ADF.
  304.  
  305.           You may insert (or call) one of the files ADFCOM1.BAT or
  306.           ADFCOM2.BAT for quick and easy editing.
  307.  
  308.           If you are using a protected mode multitasking environment, such
  309.           as Windows, load one copy of ADF in each wanted DOS session using
  310.           different ports. Do not load ADF in AUTOEXEC.BAT. In fact, this
  311.           applies for all FOSSIL drivers, and this is the reason why ADF
  312.           only uses one port per load.
  313.  
  314.  
  315.           6  Command line arguments
  316.  
  317.           When you run ADF without any arguments, it will display the
  318.           following help text (use ADF|MORE for more prompt):
  319.  
  320.           adf port addr irq baud recbuf[,hold[,cont]] trabuf [fifo] [line]
  321.             [modem]
  322.  
  323.           port    FOSSIL port number, 0-126, or COM-port, COM1-COM127.
  324.                   Example: 0 or COM1
  325.           addr    Address in hex of COM-port, 0-FFFF. Example: 3F8
  326.           irq     IRQ number of COM-port, 0-15. Example: 4
  327.           baud    Locked baud-rate, 1-115200. Example: 38400
  328.           recbuf  Size of receive buffer, 256-16384. Example: 4096
  329.           hold    Flow control hold or stop, default 7/8 of recbuf.
  330.                   Example: 3584
  331.           cont    Flow control continue or restart, default 6/8 of recbuf.
  332.                   Example: 3072
  333.           trabuf  Size of transmit buffer, 256-16384. Example: 4096
  334.           fifo    Receiver 16550-FIFO trigger level, 1, 4, 8 or 14.
  335.  
  336.  
  337.           ─────────────────────────────────────────────────────────────────
  338.           Scandinavian Digital Systems                               Page 6
  339.           AnDan Software FOSSIL Version 1.40                   Users Manual
  340.           ─────────────────────────────────────────────────────────────────
  341.  
  342.  
  343.                   Default: 8
  344.                   Or 16650,rec,tra for setting receiver trigger level 8,
  345.                   16, 24 or 28, and transmitter trigger level 8, 16, 24 or
  346.                   30 on 16650. Example: 16650,16,8
  347.           line    Line control register. Default: 3
  348.           modem   Modem control register. Default: 11
  349.  
  350.           ADF will stay resident when using the above command line.
  351.  
  352.           adf unload
  353.  
  354.           ADF will remove itself from memory when using the above command
  355.           line.
  356.  
  357.           adf watch on|off
  358.  
  359.           ADF will turn carrier watchdog on or off when using the above
  360.           command line.
  361.  
  362.  
  363.           6.1  port
  364.  
  365.           You may specify the FOSSIL port number starting with 0 by using a
  366.           number only, or you may specify the port number starting with 1
  367.           by putting COM before the number, that is 0 = COM1, 1 = COM2 and
  368.           so on. In practice, ADF sets no limits, but your environment may
  369.           limit the number of COM ports.
  370.  
  371.           The FOSSIL port number is only used to check for correct calls by
  372.           application programs. ADF doesn't use this number to access the
  373.           port or anything like that. You always need to specify the
  374.           address and IRQ of the port.
  375.  
  376.  
  377.           6.2  addr
  378.  
  379.           Address in hexadecimal notation of the COM port, see irq.
  380.  
  381.  
  382.           6.3  irq
  383.  
  384.           IRQ of the COM port. The most common addresses and IRQs are:
  385.  
  386.               COM1    3F8    4
  387.               COM2    2F8    3
  388.               COM3    3E8    4
  389.               COM4    2E8    3
  390.  
  391.           Note that you cannot use two COM ports having the same IRQ. If
  392.           you configure your hardware using the same IRQ to two COM ports,
  393.           you must be very sure that they are not used at the same time and
  394.           that programs using them turns them of when finished. Otherwise
  395.           you will get a true electrical short-circuit.
  396.  
  397.  
  398.  
  399.           ─────────────────────────────────────────────────────────────────
  400.           Scandinavian Digital Systems                               Page 7
  401.           AnDan Software FOSSIL Version 1.40                   Users Manual
  402.           ─────────────────────────────────────────────────────────────────
  403.  
  404.  
  405.           6.4  baud
  406.  
  407.           The baud rate to use (lock). Common values are 9600, 19200,
  408.           38400, 56700 and 115200. See chapter 8 for details.
  409.  
  410.  
  411.           6.5  recbuf,hold,cont
  412.  
  413.           The receive buffer size in bytes. Use at least 1024, but it
  414.           should not need to be much larger than your maximum cps rate.
  415.           4096 is a good value for high speed modems.
  416.  
  417.           Optionally, you may use commas and specify the receive flow
  418.           control trigger levels. When the number of bytes in the receive
  419.           buffer is more than the "hold" value, RTS will be lowered. Then
  420.           when the number of bytes has gone below the "cont" value, RTS
  421.           will be raised again.
  422.  
  423.           Note that some modems ignores the RTS signal, in practice it will
  424.           work anyway, at least with large enough receive buffer.
  425.  
  426.  
  427.           6.6  trabuf
  428.  
  429.           The transmit buffer size in bytes. Use at least 1024, but it
  430.           should not need to be much larger than your maximum cps rate.
  431.           4096 is a good value for high speed modems.
  432.  
  433.  
  434.           6.7  fifo
  435.  
  436.           The 16550 FIFO receiver trigger level. A value of 1, 4, 8 or 14
  437.           bytes. Please see chapter 9 for details. If you don't specify
  438.           this on the command line, a trigger level of 8 bytes will be used
  439.           by default. If you don't have a 16550 or compatible, ADF will
  440.           still set the trigger level, but it will have no effect.
  441.  
  442.           Instead of the 16550 FIFO receiver trigger level, you may specify
  443.           the number 16650, meaning you got a 16650 UART with 2x32 bytes
  444.           FIFO and other enhancements. When you use 16650 you must also
  445.           specify the 16650 FIFO receiver and transmitter trigger levels
  446.           separated with commas.
  447.  
  448.  
  449.           6.8  line
  450.  
  451.           The value to put in the UART's Line Control Register. This is an
  452.           advanced option. If you want 8N1 (like most users) you don't need
  453.           to worry about this option. The Line Control Register is a bit
  454.           register, you need to add the values wanted.
  455.  
  456.           Value:  Meaning:
  457.  
  458.  
  459.  
  460.  
  461.           ─────────────────────────────────────────────────────────────────
  462.           Scandinavian Digital Systems                               Page 8
  463.           AnDan Software FOSSIL Version 1.40                   Users Manual
  464.           ─────────────────────────────────────────────────────────────────
  465.  
  466.  
  467.              0    5 data bits
  468.              1    6 data bits
  469.              2    7 data bits
  470.              3    8 data bits
  471.              4    2 stop bits
  472.              8    Parity Enable
  473.             16    Even Parity
  474.             32    Stick Parity
  475.  
  476.           Common combinations:
  477.  
  478.             8N1   3
  479.             7O1   10 (2+8)
  480.             7E1   26 (2+8+16)
  481.  
  482.  
  483.           6.9  modem
  484.  
  485.           The value to put in the UART's Modem Control Register. This is an
  486.           advanced option. If you have a 100% PC compatible you should not
  487.           use this option. The Modem Control Register is a bit register,
  488.           you need to add the values wanted. This value is loaded into the
  489.           register when application programs calls for a FOSSIL
  490.           initialization. Some bits (like DTR, RTS and Out2) are modified
  491.           by ADF during execution.
  492.  
  493.           Value:  Meaning:
  494.  
  495.             1     Data Terminal Ready, DTR
  496.             2     Request to Send, RTS
  497.             4     Out1
  498.             8     Out2, On PC compatibles, the Out2 signal is used to mask
  499.                   the IRQ signal. IRQ must not be masked for ADF to work.
  500.            16     Loopback
  501.            32     16650 only: Open source (emitter) interrupt output, for
  502.                   shared interrupts. (ADF has no special shared interrupt
  503.                   capabilities).
  504.            64     16650 only: Infrared RXD/TXD
  505.           128     16650 only using 7.372 MHz clock: Divided by four baud
  506.                   clock
  507.  
  508.  
  509.           7  Execution examples
  510.  
  511.           Example of loading ADF using COM1 (see ADFCOM1.BAT):
  512.  
  513.           adf COM1 3F8 4 38400 4096 4096 8
  514.  
  515.  
  516.           Example of loading ADF using COM2 (see ADFCOM2.BAT):
  517.  
  518.           adf COM2 2F8 3 38400 4096 4096 8
  519.  
  520.  
  521.  
  522.  
  523.           ─────────────────────────────────────────────────────────────────
  524.           Scandinavian Digital Systems                               Page 9
  525.           AnDan Software FOSSIL Version 1.40                   Users Manual
  526.           ─────────────────────────────────────────────────────────────────
  527.  
  528.  
  529.           Example of loading ADF with 16650:
  530.  
  531.           adf COM1 3F8 4 38400 4096 4096 16650,16,8
  532.  
  533.  
  534.           Example of loading ADF with 7E1:
  535.  
  536.           adf COM1 3F8 4 38400 4096 4096 8 26
  537.  
  538.  
  539.           Example of unloading ADF:
  540.  
  541.           adf unload
  542.  
  543.  
  544.           Example of REMOTE.BAT, to execute on DOS-Shell in a BBS:
  545.  
  546.           @echo off
  547.           rem %1 = Baud rate (used to detect local call)
  548.           if not %1@==0@ ctty COM%2
  549.           if not %1@==0@ adf watch on
  550.           command
  551.           adf watch off
  552.           ctty CON
  553.  
  554.           The carrier watchdog will try to reboot the computer after about
  555.           10 seconds from the carrier drops. This may be dangerous,
  556.           especially in a multitasking environment (such as Windows).
  557.  
  558.  
  559.           8  Baud rate calculation
  560.  
  561.           A PC compatible serial port uses the following formula to
  562.           calculate the baud rate:
  563.  
  564.           Baud = 115200 / Divisor
  565.  
  566.           The Divisor is an integer number (whole number), 1 to 65535, used
  567.           to program the serial port (the UART chip). This means that only
  568.           certain baud rates are allowed.
  569.  
  570.           Divisor:        Baud rate:
  571.  
  572.              1            115200 bps
  573.              2             57600 bps
  574.              3             38400 bps
  575.              4             28800 bps
  576.              5             23040 bps
  577.              6             19200 bps
  578.              7             16457 bps
  579.              8             14400 bps
  580.              9             12800 bps
  581.             10             11520 bps
  582.             11             10473 bps
  583.  
  584.  
  585.           ─────────────────────────────────────────────────────────────────
  586.           Scandinavian Digital Systems                              Page 10
  587.           AnDan Software FOSSIL Version 1.40                   Users Manual
  588.           ─────────────────────────────────────────────────────────────────
  589.  
  590.  
  591.             12              9600 bps
  592.              .               .
  593.              .               .
  594.              X             115200/X
  595.              .               .
  596.              .               .
  597.  
  598.  
  599.           When you specify a baud rate on the command line to ADF, ADF
  600.           calculates the Divisor and checks that the baud-rate is valid
  601.           (realizable).
  602.  
  603.           If you for example use 76800 bps as a baud rate to ADF, the
  604.           Divisor will be 115200/76800 = 1.5, but this is not an integer
  605.           (whole number) and cannot be set. ADF will in this case display
  606.           an error message.
  607.  
  608.  
  609.           9  16550 and 16650 FIFO UARTs
  610.  
  611.           ADF has full support of the 16550 and the 16650 UART. These UARTs
  612.           are enhanced replacements of the standard 8250 and 16450 UARTs,
  613.           using hardware buffers to get higher performance.
  614.  
  615.           These buffers are called FIFO (First In First Out) buffers.
  616.  
  617.           The 16550 has one 16 byte large receiver FIFO buffer, and one 16
  618.           bytes large transmitter FIFO buffer.
  619.  
  620.           The 16650 has one 32 byte large receiver FIFO buffer, and one 32
  621.           bytes large transmitter FIFO buffer.
  622.  
  623.           On the 16550, you may set the trigger level of the receiver FIFO
  624.           buffer, and on the 16650, you may set the trigger level of both
  625.           the receiver and transmitter FIFOs.
  626.  
  627.  
  628.           9.1  Receiver 16550-FIFO trigger level
  629.  
  630.           The receiver 16550-FIFO trigger level can be set to 1, 4, 8 or 14
  631.           bytes of it's total 16 bytes buffer size.
  632.  
  633.           The value is the number of bytes in the receiver FIFO buffer that
  634.           will generate an interrupt from the UART to the CPU.
  635.  
  636.           The receiver FIFO buffer and it's trigger level, is the main
  637.           reason why many people replaces their old 8250 and 16450 UARTs
  638.           with 16550.
  639.  
  640.           If you for example use a baud rate of 38400 bps (8N1), there will
  641.           be a new byte received each 260 us (microseconds). With an
  642.           ordinary UART, the CPU must answer to an interrupt from the UART
  643.           each 260 us, and read the byte and store it in memory.
  644.  
  645.  
  646.  
  647.           ─────────────────────────────────────────────────────────────────
  648.           Scandinavian Digital Systems                              Page 11
  649.           AnDan Software FOSSIL Version 1.40                   Users Manual
  650.           ─────────────────────────────────────────────────────────────────
  651.  
  652.  
  653.           If the CPU is unable to answer an interrupt at this rate, or if
  654.           some program has disable interrupts longer than 260 us, received
  655.           bytes will be lost. If you are downloading a file, you will get a
  656.           lot of resends.
  657.  
  658.           The 16550 UART has a 16 byte receiver FIFO buffer (and also a 16
  659.           byte transmitter FIFO) so it can store up to 16 bytes until the
  660.           CPU must read and empty the buffer.
  661.  
  662.           The receiver FIFO trigger level specifies when an interrupt
  663.           should be generated by the UART to the CPU.
  664.  
  665.           If the trigger level is set to 4, the UART will generate an
  666.           interrupt after 4 bytes have been received, but will still fill
  667.           the buffer up to 16 bytes if the CPU doesn't answer the
  668.           interrupt. The rate of interrupts at 38400 bps will be
  669.           4*260 = 1040 us, and the tolerance to no answer from the CPU will
  670.           be (16-4)*260 = 3120 us.
  671.  
  672.           The most common problem with high baud rates, is that programs
  673.           turns of interrupts during too long time. A trigger level of 14
  674.           would in most cases not be a good solution, normally a trigger
  675.           level of 8 is good enough, in some cases you may lower it to 4.
  676.           You should not choose a lower trigger level then necessary,
  677.           because it would load the CPU without giving any benefits.
  678.  
  679.  
  680.           9.2  Receiver 16650-FIFO trigger level
  681.  
  682.           The receiver 16650-FIFO trigger level can be set to 8, 16, 24 or
  683.           28 bytes of it's total 32 bytes buffer size.
  684.  
  685.           It's similar to the 16550-FIFO, see section 9.1 above, but it
  686.           will have higher tolerance against CPU response time and it will
  687.           load the CPU even less.
  688.  
  689.  
  690.           9.3  Transmitter 16650-FIFO trigger level
  691.  
  692.           The transmitter 16650-FIFO trigger level can be set to 8, 16, 24
  693.           or 30 bytes of it's total 32 bytes buffer size.
  694.  
  695.           This setting cannot be done on the 16550. The 16550 always has
  696.           it's transmitter FIFO trigger level set to 1 by hardware.
  697.  
  698.           When the number of not yet transmitted bytes in the FIFO goes
  699.           below the trigger level, the UART will generate an interrupt to
  700.           the CPU, so the interrupt service program can fill up the FIFO
  701.           with more characters to transmit.
  702.  
  703.           The setting of the transmitter FIFO trigger level will affect how
  704.           much the transmission will load the CPU, and how fast the
  705.           transmission may be.
  706.  
  707.  
  708.  
  709.           ─────────────────────────────────────────────────────────────────
  710.           Scandinavian Digital Systems                              Page 12
  711.           AnDan Software FOSSIL Version 1.40                   Users Manual
  712.           ─────────────────────────────────────────────────────────────────
  713.  
  714.  
  715.           A lower trigger level means less CPU load, but maybe lower
  716.           transfer rates if long interrupt response times.
  717.  
  718.           A higher trigger level means higher transfer rates on systems
  719.           with long interrupt response times, but it will load the CPU
  720.           more.
  721.  
  722.  
  723.           10 Error messages
  724.  
  725.           When ADF displays an error message, it will wait a moment before
  726.           continuing, so you are able to read the message when ADF is
  727.           executed among other programs in batch files (such as
  728.           AUTOEXEC.BAT).
  729.  
  730.           All error messages with explanations:
  731.  
  732.  
  733.           "Argument error (command line error)."
  734.  
  735.           ADF was unable to understand the command line arguments, please
  736.           see section 6 above. This error message will also be displayed if
  737.           numerical values on the command line are out of range.
  738.  
  739.  
  740.           "DOS v3.1 or newer required."
  741.  
  742.           Your DOS is too old, you need to upgrade to a newer DOS version.
  743.  
  744.  
  745.           "Unable to handle TSRs in this environment."
  746.  
  747.           ADF does a check that it can search and find it self in the DOS
  748.           memory (lower or upper). If this fails it will display this
  749.           message. Try using plain DOS without special memory managers or
  750.           program loaders.
  751.  
  752.  
  753.           "Error when releasing memory."
  754.  
  755.           DOS reports error when freeing memory. This can occur during both
  756.           load and unload of ADF. Probably is the DOS memory allocation
  757.           blocks damaged (by some program).
  758.  
  759.  
  760.           "Invalid (not realizable) baud-rate."
  761.  
  762.           The specified baud-rate cannot be used. Please see section 8
  763.           above.
  764.  
  765.  
  766.           "Not enough memory for buffers."
  767.  
  768.  
  769.  
  770.  
  771.           ─────────────────────────────────────────────────────────────────
  772.           Scandinavian Digital Systems                              Page 13
  773.           AnDan Software FOSSIL Version 1.40                   Users Manual
  774.           ─────────────────────────────────────────────────────────────────
  775.  
  776.  
  777.           The memory given to ADF by DOS at load time is not enough to
  778.           satisfy the wanted size of the receive and transmit buffers.
  779.           Decrease the sizes or load ADF in low memory or in a larger high
  780.           memory block.
  781.  
  782.  
  783.           "Error when restoring interrupts."
  784.  
  785.           This may occur when unloading ADF. Most common cause is that some
  786.           other programs also are using the same interrupts. Try to unload
  787.           all TSRs in the reverse order of how they where loaded.
  788.  
  789.  
  790.           "ADF already loaded."
  791.  
  792.           This message will be displayed if you try to load ADF a second
  793.           time.
  794.  
  795.  
  796.           "ADF not loaded."
  797.  
  798.           This message will be displayd if you use some of the ADF command
  799.           lines that requires ADF to be loaded as a TSR first (e.g. unload
  800.           and watch).
  801.  
  802.  
  803.           "Please run "REGISTER" first to use this program."
  804.  
  805.           You must run REGISTER.EXE to use ADF.EXE, see section 2 above. If
  806.           you get a new version of ADF.EXE you need to run REGISTER.EXE
  807.           once again.
  808.  
  809.  
  810.           "You have used this program for more than 30 days. If you want to
  811.           use it more, you must register it. Please wait a moment."
  812.  
  813.           Please read section 2 above. ADF will wait a moment when
  814.           displaying this message, you cannot terminate this waiting.
  815.  
  816.  
  817.           11 Benchmarks
  818.  
  819.           Users have asked how much memory ADF will consume and how fast it
  820.           is compared with other well known FOSSIL drivers.
  821.  
  822.           Below are tables of memory consumption and execution speed.
  823.  
  824.           X00 v1.50 and BNU v1.70 have been used as references.
  825.  
  826.           The drivers where loaded using the following command lines:
  827.  
  828.           adf 0 3F8 4 38400 2048 1024 8
  829.           x00 E 0=3F8,IRQ4 B,0,38400 R=2048 T=1024
  830.           bnu /T1024 /R2048 /P1 /L0:38400,8N1
  831.  
  832.  
  833.           ─────────────────────────────────────────────────────────────────
  834.           Scandinavian Digital Systems                              Page 14
  835.           AnDan Software FOSSIL Version 1.40                   Users Manual
  836.           ─────────────────────────────────────────────────────────────────
  837.  
  838.  
  839.           Please note that ADF has not been written with any special
  840.           efforts to make it small and fast. These benchmarks are only
  841.           included here to show that ADF is as good as any other FOSSIL
  842.           driver written in the assembly language.
  843.  
  844.  
  845.           11.1 Memory consumption
  846.  
  847.           How much memory ADF (and other FOSSILs) will use depends on how
  848.           large receive and transmit buffers are being used.
  849.  
  850.           The memory consumption was determined using the DOS command
  851.           MEM /d.
  852.  
  853.           Program:        Bytes used:
  854.  
  855.           ADF.EXE          6480 bytes
  856.           X00.SYS          9808 bytes
  857.           X00.EXE         10288 bytes + environment size
  858.           BNU.SYS          8272 bytes
  859.           BNU.EXE          8304 bytes + environment size
  860.  
  861.           Probably due to ADF uses only locked baud and always one port, it
  862.           is somewhat smaller than the others.
  863.  
  864.  
  865.           11.2 Execution speed
  866.  
  867.           The execution speed has been measured using ADFDebug and ADFTest
  868.           (see below). ADFTest was executed 8 times per FOSSIL, and the
  869.           most common value was used.
  870.  
  871.           The computer used was a 486DX-50 with no significant TSRs. The
  872.           internal cache (8 KB) and the external cache were both disabled.
  873.  
  874.           Each time value has the unit 0.838095 us (microseconds).
  875.  
  876.  
  877.           FOSSIL function:                       ADF:   X00:   BNU:
  878.  
  879.           00 Set communications parameters        82    134    121
  880.           01 Transmit character and wait          78    191     94
  881.           02 Get received character with wait     56     80     56
  882.           03 Return serial port status            63     81     53
  883.           04 Activate port                       106    587  35885
  884.           05 Deactivate port                      65    275    238
  885.           06 Raise/lower DTR                      43     61     67
  886.           07 Return timer tick information        33     38     39
  887.           08 Flush output buffer                  41     77     46
  888.           09 Purge output buffer                  41     65     48
  889.           0A Purge input buffer                   43     77     53
  890.           0B Transmit no wait                     58    104     75
  891.           0C Non-destructive read-ahead           50     63     52
  892.           0F Flow control for serial I/O          43     65     47
  893.  
  894.  
  895.           ─────────────────────────────────────────────────────────────────
  896.           Scandinavian Digital Systems                              Page 15
  897.           AnDan Software FOSSIL Version 1.40                   Users Manual
  898.           ─────────────────────────────────────────────────────────────────
  899.  
  900.  
  901.           18 Block Read                           73   1200     92
  902.           19 Block Write                          87   1322    110
  903.  
  904.  
  905.           These values should be compared with care. All three FOSSIL
  906.           drivers have about the same execution speed on most functions.
  907.           Only large differences (25% or more) are to be considered.
  908.  
  909.           Due to difference in implementation, some function takes much
  910.           longer time, for example, BNU writes to the screen during
  911.           function 01 Activate port.
  912.  
  913.           One thing to remember is that ADF actually does more job for all
  914.           read, write (transmit) and status functions, due to safer
  915.           operation with protected mode multitaskers using emulated UARTs.
  916.           As you can see, this has been achieved without any significant
  917.           time losses.
  918.  
  919.           The function 18H (Block Read) transferred 45 bytes, and the
  920.           function 19H (Block Write) transferred 39 bytes in the above
  921.           test. Modern and well written application programs uses these
  922.           functions most, and during file transfers the number of bytes
  923.           will of course be much larger, giving larger difference between
  924.           the FOSSIL drivers.
  925.  
  926.           Note that no execution speed of the interrupt services routine
  927.           has been measured. However, we are convinced that ADF's interrupt
  928.           services routine is as fast as any other FOSSIL.
  929.  
  930.           The very best benchmark is of course testing and measuring in
  931.           real use with application software.
  932.  
  933.  
  934.           12 The ADFComCh program
  935.  
  936.           When you run ADFComCh without any arguments, it will display the
  937.           following help text:
  938.  
  939.           adfcomch addr
  940.  
  941.           addr    Address in hex of COM port, 0-FFFF. Example: 3F8
  942.  
  943.           ADFComCh checks if there is an UART at the specified port
  944.           address. The most common port addresses are:
  945.  
  946.               COM1    3F8
  947.               COM2    2F8
  948.               COM3    3E8
  949.               COM4    2E8
  950.  
  951.           The current UART settings will be cleared or modified. Please
  952.           reboot or load ADF after usage. Sets ERRORLEVEL to:
  953.  
  954.  
  955.  
  956.  
  957.           ─────────────────────────────────────────────────────────────────
  958.           Scandinavian Digital Systems                              Page 16
  959.           AnDan Software FOSSIL Version 1.40                   Users Manual
  960.           ─────────────────────────────────────────────────────────────────
  961.  
  962.  
  963.           255  Error
  964.             4  No UART
  965.             3  16450
  966.             2  16550
  967.             1  16650
  968.  
  969.  
  970.           13 The ADFDebug program
  971.  
  972.           When you run ADFDebug without any arguments, it will display the
  973.           following help text:
  974.  
  975.           adfdebug command
  976.  
  977.           'command' is one of the following commands:
  978.  
  979.           L [opt] Load TSR, should be done after the FOSSIL load. Options:
  980.                   /t    Use time measurement.
  981.                   /sNN  Use ASCII NN as separator, default is 13 and 10 (CR
  982.                   and LF).
  983.           U       Unload TSR, should be done before the FOSSIL unload.
  984.           N       No output (default at load time).
  985.           S       Screen output.
  986.           F file  File output to the specified file.
  987.  
  988.  
  989.           13.1 Using ADFDebug
  990.  
  991.           ADFDebug is a FOSSIL debugger. It is loaded as a TSR after the
  992.           FOSSIL has been loaded, and may write debug (trace) information
  993.           to the screen or to a file.
  994.  
  995.           It is included for application programmers, and for advanced
  996.           users.
  997.  
  998.           ADFDebug is loaded using the command L with or without the
  999.           options /t or /s. If /t is used, it will do time measurements of
  1000.           the FOSSIL driver functions using timer ticks with the unit
  1001.           0.838095 us (microseconds). The time will always include a small
  1002.           offset error, independent of the FOSSIL driver used. Execution
  1003.           time of interrupts that occurs during FOSSIL execution will be
  1004.           included in the time measurement.
  1005.  
  1006.           When loading with the option /t, ADFDebug may cause the internal
  1007.           DOS clock (BIOS Timer Tick) to be incorrectly updated. Do only
  1008.           use /t in plain DOS without any timer depending TSRs, including
  1009.           hard disk caches (e.g. smartdrv), and reboot when done with
  1010.           testing. During testing, do not hold down keys or move the mouse.
  1011.  
  1012.           After loading ADFDebug, the command S or F is used to start debug
  1013.           output, and the command N is used to stop the output.
  1014.  
  1015.           When using the command F, you must also specify a file name. The
  1016.           file is opened, written to and closed at each FOSSIL call, so
  1017.  
  1018.  
  1019.           ─────────────────────────────────────────────────────────────────
  1020.           Scandinavian Digital Systems                              Page 17
  1021.           AnDan Software FOSSIL Version 1.40                   Users Manual
  1022.           ─────────────────────────────────────────────────────────────────
  1023.  
  1024.  
  1025.           most programs using the FOSSIL will run very slow. The file may
  1026.           also get very large.
  1027.  
  1028.           ADFDebug uses DOS to write to the file, which may cause a system
  1029.           crash when the FOSSIL is used by some programs (programs that
  1030.           calls the FOSSIL from interrupt routines).
  1031.  
  1032.           For testing purposes the program ADFTest (see below) is included.
  1033.           It calls a lot of FOSSIL functions, and the calls are done
  1034.           immediate after a BIOS Timer Tick count, to minimize time
  1035.           measurement errors.
  1036.  
  1037.           Example of usage of ADFDebug and ADFTest:
  1038.  
  1039.           @echo off
  1040.           del adf.lst
  1041.           adf COM1 3F8 4 38400 2048 1024 8
  1042.           adfdebug L /t /s9
  1043.           adfdebug F adf.lst
  1044.           adftest COM1
  1045.           adfdebug U
  1046.           adf unload
  1047.  
  1048.  
  1049.           14 The ADFTerm program
  1050.  
  1051.           When you run ADFTerm without any arguments, it will display the
  1052.           following help text:
  1053.  
  1054.           adfterm port
  1055.  
  1056.           port    FOSSIL port number, 0-126, or COM-port, COM1-COM127.
  1057.                   Example: 0 or COM1
  1058.  
  1059.           ADFTerm is a very small and simple communication program, that
  1060.           uses the ADF or any FOSSIL driver. It will set 2400 bps and 8N1
  1061.           if FOSSIL is not locked.
  1062.  
  1063.           You may call BBSes and use ANSI-BBS if you have ANSI.SYS loaded.
  1064.  
  1065.  
  1066.           15 The ADFTest program
  1067.  
  1068.           When you run ADFTest without any arguments, it will display the
  1069.           following help text:
  1070.  
  1071.           adftest port
  1072.  
  1073.           port    FOSSIL port number, 0-126, or COM-port, COM1-COM127.
  1074.                   Example: 0 or COM1
  1075.  
  1076.           ADFTest is a FOSSIL test program.
  1077.  
  1078.  
  1079.  
  1080.  
  1081.           ─────────────────────────────────────────────────────────────────
  1082.           Scandinavian Digital Systems                              Page 18
  1083.           AnDan Software FOSSIL Version 1.40                   Users Manual
  1084.           ─────────────────────────────────────────────────────────────────
  1085.  
  1086.  
  1087.           ADFTest will send "ATE1<cr>" to the port and expect at least one
  1088.           character as reply. A modem connected to the port will in most
  1089.           cases do the job.
  1090.  
  1091.           ADFTest is intended to be used with ADFDebug for testing and
  1092.           verifying FOSSIL drivers.
  1093.  
  1094.  
  1095.           16 Version history
  1096.  
  1097.           v1.10 November 22, 1995
  1098.  
  1099.           This is the first non-BETA version. The setting of the receiver
  1100.           FIFO trigger level on the command line has been added since the
  1101.           v1.00 BETAs from 1994.
  1102.  
  1103.  
  1104.           v1.20 December 9, 1995
  1105.  
  1106.           Many improvements and bug fixes has been done. ADF now includes
  1107.           all FOSSIL functions 01H to 21H as X00 v1.50 does. It also
  1108.           includes function 7EH and 7FH for "external application". ADF
  1109.           will now display an error message if the baud-rate is not
  1110.           realizable. Some more utility programs have been included, the
  1111.           debug function has been moved into a separate program (option /d
  1112.           is no longer valid).
  1113.  
  1114.  
  1115.           v1.30 January 20, 1996
  1116.  
  1117.           Bugfix of External Application. Added output of flag register in
  1118.           ADFDebug. Bugfix of function 1E "Extended line control
  1119.           initialization". Bugfix of function 04, 05, 1C, 14 when used on
  1120.           illegal port number. Only check DL for port number (due to bugs
  1121.           in other programs), valid port range is now 0-126. COM-port
  1122.           number may be used instead of FOSSIL port number.
  1123.  
  1124.  
  1125.           v1.31 January 22, 1996
  1126.  
  1127.           The time limit of 30 days after installation has been removed.
  1128.           ADF will not stop executing after 30 days as before, it will run
  1129.           for ever, even if it is never registered.
  1130.  
  1131.  
  1132.           v1.32 February 9, 1996
  1133.  
  1134.           Bugfix of External Application, such as Video FOSSIL.
  1135.  
  1136.  
  1137.           v1.40 March 23, 1996
  1138.  
  1139.           Bugfix when input buffer was purged the RTS signal was not
  1140.           restored (activated, made high) if it had been lowered due to
  1141.  
  1142.  
  1143.           ─────────────────────────────────────────────────────────────────
  1144.           Scandinavian Digital Systems                              Page 19
  1145.           AnDan Software FOSSIL Version 1.40                   Users Manual
  1146.           ─────────────────────────────────────────────────────────────────
  1147.  
  1148.  
  1149.           flow control. Receiver flow control hold and continue levels may
  1150.           now be specified on the command line. Improved block read and
  1151.           write (function 18H and 19H) for higher speed. ADFTest uses ATE1
  1152.           to test block read/write with more characters. User settings of
  1153.           line and modem control registers. Included support for 16650.
  1154.           REGISTER.EXE v1.20 needed to register. Documentation improved.
  1155.  
  1156.  
  1157.           17 Future versions
  1158.  
  1159.           As long as people keep registering and using ADF, we will
  1160.           continue to make new versions, to improve ADF and to support
  1161.           future UARTs and environments to come.
  1162.  
  1163.           On demand from many users, I (the author of ADF) will as soon as
  1164.           I get information describing how to make device drivers for
  1165.           Windows v3.1, Windows 95 and OS/2 v3, probably make enhanced and
  1166.           fast communication drivers for these operating systems, with
  1167.           support for DOS FOSSIL applications.
  1168.  
  1169.  
  1170.  
  1171.  
  1172.  
  1173.  
  1174.  
  1175.  
  1176.  
  1177.  
  1178.  
  1179.  
  1180.  
  1181.  
  1182.  
  1183.  
  1184.  
  1185.  
  1186.  
  1187.  
  1188.  
  1189.  
  1190.  
  1191.  
  1192.  
  1193.  
  1194.  
  1195.  
  1196.  
  1197.  
  1198.  
  1199.  
  1200.  
  1201.  
  1202.  
  1203.  
  1204.  
  1205.           ─────────────────────────────────────────────────────────────────
  1206.           Scandinavian Digital Systems                              Page 20
  1207.